home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 2: Applications / Linux Cubed Series 2 - Applications.iso / editors / emacs / xemacs / xemacs-1.004 / xemacs-1 / xemacs-19.13 / src / m / aviion.h < prev    next >
Encoding:
C/C++ Source or Header  |  1995-07-28  |  4.1 KB  |  123 lines

  1. /* machine description file for Data General AViiON.
  2.    Copyright (C) 1985, 1986, 1991 Free Software Foundation, Inc.
  3.  
  4. This file is part of GNU Emacs.
  5.  
  6. GNU Emacs is free software; you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 2, or (at your option)
  9. any later version.
  10.  
  11. GNU Emacs is distributed in the hope that it will be useful,
  12. but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14. GNU General Public License for more details.
  15.  
  16. You should have received a copy of the GNU General Public License
  17. along with GNU Emacs; see the file COPYING.  If not, write to
  18. the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  19.  
  20. /* Synched up with: FSF 19.29. */
  21.  
  22. /* Define WORD_MACHINE if addresses and such have
  23.  * to be corrected before they can be used as byte counts.  */
  24.  
  25. #define WORD_MACHINE
  26.  
  27. /* Define DATA_SEG_BITS if pointers need to be corrected with
  28.    a segment field.  */
  29.  
  30. #ifdef FIX_ADDRESS
  31. #define DATA_SEG_BITS 0xef000000
  32. #endif
  33.  
  34. /* Now define a symbol for the cpu type, if your compiler
  35.    does not define it automatically:
  36.    Ones defined so far include vax, m68000, ns16000, pyramid,
  37.    orion, tahoe, APOLLO and many others */
  38.  
  39. #ifndef m88k
  40. #define m88k
  41. #endif
  42.  
  43. /* Use type int rather than a union, to represent Lisp_Object */
  44. /* This is desirable for most machines.  */
  45.  
  46. #define NO_UNION_TYPE
  47.  
  48. /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
  49.    the bit field into an int.  In other words, if bit fields
  50.    are always unsigned.
  51.  
  52.    If you use NO_UNION_TYPE, this flag does not matter.  */
  53.  
  54. #define EXPLICIT_SIGN_EXTEND
  55.  
  56. /* Data type of load average, as read out of kmem.  */
  57.  
  58. /* #define LOAD_AVE_TYPE long */
  59.  
  60. /* Convert that into an integer that is 100 for a load average of 1.0  */
  61.  
  62. /* #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE) */
  63.  
  64. /* Define CANNOT_DUMP on machines where unexec does not work.
  65.    Then the function dump-emacs will not be defined
  66.    and temacs will do (load "loadup") automatically unless told otherwise.  */
  67.  
  68. /* #define CANNOT_DUMP */
  69.  
  70. /* Define VIRT_ADDR_VARIES if the virtual addresses of
  71.    pure and impure space as loaded can vary, and even their
  72.    relative order cannot be relied on.
  73.  
  74.    Otherwise Emacs assumes that text space precedes data space,
  75.    numerically.  */
  76.  
  77. /* #define VIRT_ADDR_VARIES */
  78.  
  79. /* Define C_ALLOCA if this machine does not support a true alloca
  80.    and the one written in C should be used instead.
  81.    Define HAVE_ALLOCA to say that the system provides a properly
  82.    working alloca function and it should be used.
  83.    Define neither one if an assembler-language alloca
  84.    in the file alloca.s should be used.  */
  85.  
  86. /* #define C_ALLOCA */
  87. #define HAVE_ALLOCA
  88. #define alloca(x) __builtin_alloca(x)
  89.  
  90. /* Define NO_REMAP if memory segmentation makes it not work well
  91.    to change the boundary between the text section and data section
  92.    when Emacs is dumped.  If you define this, the preloaded Lisp
  93.    code will not be sharable; but that's better than failing completely.  */
  94.  
  95. #define NO_REMAP
  96.  
  97. /* Define ADDR_CORRECT(ADDR) to be a macro to correct an int which is
  98.    the bit pattern of a pointer to a byte into an int which is the
  99.    number of a byte.
  100.  
  101.    This macro has a default definition which is usually right.
  102.    This default definition is a no-op on most machines (where a
  103.    pointer looks like an int) but not on all machines. */
  104.  
  105. #define    ADDR_CORRECT(ADDR) ((int)ADDR)
  106.  
  107. /* Cast pointers to this type to compare them. */
  108.  
  109. #define    PNTR_COMPARISON_TYPE    void *
  110.  
  111. /* Some machines that use COFF executables require that each section
  112.    start on a certain boundary *in the COFF file*.  Such machines should
  113.    define SECTION_ALIGNMENT to a mask of the low-order bits that must be
  114.    zero on such a boundary.  This mask is used to control padding between
  115.    segments in the COFF file.
  116.  
  117.    If SECTION_ALIGNMENT is not defined, the segments are written
  118.    consecutively with no attempt at alignment.  This is right for
  119.    unmodified system V.  */
  120.  
  121. #define SECTION_ALIGNMENT 0x7
  122.  
  123.